A typical code smell known as unused function parameters refers to parameters declared in a function but not used anywhere within the function’s
body. While this might seem harmless at first glance, it can lead to confusion and potential errors in your code. Disregarding the values passed to
such parameters, the function’s behavior will be the same, but the programmer’s intention won’t be clearly expressed anymore. Therefore, removing
function parameters that are not being utilized is considered best practice.
Exceptions
Functions in classes that override a class or implement interfaces are ignored.
class C extends B {
function doSomething($a, $b) { // no issue reported on $b
compute($a);
}
}
Additionally, methods with specific Magento plugin signatures are ignored because Magento requires these parameters:
- Methods starting with
before and having at least 3 parameters
- Methods starting with
around and having at least 4 parameters
- Methods starting with
after and having at least 2 parameters
class ExamplePlugin {
public function beforeAction($subject, $arg1, $arg2) {
// no issue on unused parameters, required by Magento plugin signature
return;
}
public function aroundAction($subject, callable $proceed, $arg1, $arg2) {
// no issue on unused parameters, required by Magento plugin signature
return;
}
public function afterAction($subject, $result) {
// no issue on unused parameters, required by Magento plugin signature
return;
}
}